<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="utf-8">
    <title>商品列表</title>
    <meta name="renderer" content="webkit">
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
    <meta name="apple-mobile-web-app-status-bar-style" content="black">
    <meta name="apple-mobile-web-app-capable" content="yes">
    <meta name="format-detection" content="telephone=no">
    <link rel="stylesheet" href="/layui/css/layui.css" media="all"/>
    <link rel="stylesheet" href="/css/public.css" media="all"/>
</head>
<body class="childrenBody">
<blockquote class="layui-elem-quote quoteBox">
    <form class="layui-form" method="post" id="searchFrm">
        <div class="layui-form-item" style="text-align: center;">
            <div class="layui-inline">
                <label class="layui-form-label">供应商:</label>
                <div class="layui-input-inline">
                    <select id="searchProvider" name="providerid">
                        <option value="">请选择供应商</option>
                    </select>
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">商品名称:</label>
                <div class="layui-input-inline">
                    <input type="text" name="goodsname" placeholder="请输入商品名称" autocomplete="off" class="layui-input">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">批号:</label>
                <div class="layui-input-inline">
                    <input type="text" name="productcode" placeholder="请输入批号" autocomplete="off" class="layui-input">
                </div>
            </div>
        </div>
        <div class="layui-form-item" style="text-align: center;">
            <div class="layui-inline">
                <label class="layui-form-label">批准文号:</label>
                <div class="layui-input-inline">
                    <input type="text" name="promitcode" placeholder="请输入批准文号" autocomplete="off" class="layui-input">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">商品描述:</label>
                <div class="layui-input-inline">
                    <input type="text" name="description" placeholder="请输入商品描述" autocomplete="off" class="layui-input">
                </div>
            </div>
            <div class="layui-inline">
                <label class="layui-form-label">商品规格:</label>
                <div class="layui-input-inline">
                    <input type="text" name="size" placeholder="请输入商品规格" autocomplete="off" class="layui-input">
                </div>
            </div>
        </div>
        <div class="layui-form-item" style="text-align: center;">
            <div class="layui-inline">
                <button type="button" class="layui-btn" id="doSearch"><span class='layui-icon'>&#xe615;</span>搜索
                </button>
                <button type="reset" class="layui-btn layui-btn-danger"><span class='layui-icon'>&#xe669;</span>重置
                </button>
            </div>
        </div>
    </form>
</blockquote>
<table id="goodsTable"  lay-filter="goodsTable"></table>
<!--表头-->
<div id="goodsTableToolBar" style="display: none;">
    <a class="layui-btn layui-btn-sm" lay-event="add"><span class="layui-icon">&#xe61f;</span>添加</a>
    <a class="layui-btn layui-btn-sm layui-btn-danger" lay-event="batchdel"><span class="layui-icon">&#xe640;</span>批量删除</a>
</div>
<!--操作-->
<div id="goodsTableRowBar" style="display: none">
    <a class="layui-btn layui-btn-xs layui-btn-danger" lay-event="update">编辑</a>
    <a class="layui-btn layui-btn-xs layui-btn-danger" lay-event="del">删除</a>

</div>

<div style="display: none;padding: 3px" id="saveOrUpdateDiv">

    <form method="post" class="layui-form layui-row layui-col-space10 layui-form-pane"  id="dataFrm" lay-filter="dataFrm">
        <div class="layui-col-md9 layui-col-xs12">
            <div class="layui-row layui-col-space10">
                <div class="layui-col-md9 layui-col-xs7">
                    <div class="layui-form-item magt3">
                        <label class="layui-form-label">供应商:</label>
                        <div class="layui-input-block">

                            <input type="hidden" name="id">

                            <select id="providerid" name="providerid">
                                <option value="">请选择供应商</option>


                            </select>
                        </div>
                    </div>
                    <div class="layui-form-item">
                        <label class="layui-form-label">商品名称:</label>
                        <div class="layui-input-block">
                            <input type="text" name="goodsname" placeholder="请输入商品名称" autocomplete="off" class="layui-input">
                        </div>
                    </div>

                    <div class="layui-form-item">
                        <label class="layui-form-label">商品描述:</label>
                        <div class="layui-input-block">
                            <input type="text" name="description" placeholder="请输入商品描述" autocomplete="off" class="layui-input">
                        </div>
                    </div>

                </div>
                <div class="layui-col-md3 layui-col-xs5">
                    <div class="layui-upload-list thumbBox mag0 magt3">
                        <input type="hidden" name="goodsimg" id="goodsimg" value="/resources/images/userface3.jpg"/>
                        <img class="layui-upload-img thumbImg" src="/file/showImage?filePath=/img/1.jpg">
                    </div>
                </div>
            </div>


            <div class="layui-form-item">
                <div class="layui-inline">
                    <label class="layui-form-label">产地:</label>
                    <div class="layui-input-inline">

                        <input type="text" name="produceplace" autocomplete="off" placeholder="请输入产地"
                               class="layui-input">
                    </div>
                </div>
                <div class="layui-inline">
                    <label class="layui-form-label">包装:</label>
                    <div class="layui-input-inline">

                        <input type="text" name="goodspackage" autocomplete="off" placeholder="请输入包装"
                               class="layui-input">

                    </div>
                </div>

                <div class="layui-inline">
                    <label class="layui-form-label">规格:</label>
                    <div class="layui-input-inline">

                        <input type="text" name="size" autocomplete="off" placeholder="请输入规格"
                               class="layui-input">
                    </div>
                </div>
                <div class="layui-inline">
                    <label class="layui-form-label">生产批号:</label>
                    <div class="layui-input-inline">

                        <input type="text" name="productcode" autocomplete="off" placeholder="请输入生产批号"
                               class="layui-input">

                    </div>
                </div>

                <div class="layui-inline">
                    <label class="layui-form-label">批准文号:</label>
                    <div class="layui-input-inline">

                        <input type="text" name="promitcode" autocomplete="off" placeholder="请输入批准文号"
                               class="layui-input">
                    </div>
                </div>
                <div class="layui-inline">
                    <label class="layui-form-label">价格:</label>
                    <div class="layui-input-inline">

                        <input type="text" name="price" autocomplete="off" placeholder="请输入价格"
                               class="layui-input">

                    </div>
                </div>

                <div class="layui-inline">
                    <label class="layui-form-label">库存量:</label>
                    <div class="layui-input-inline">

                        <input type="text" name="number" autocomplete="off" placeholder="请输入产地"
                               class="layui-input">
                    </div>
                </div>
                <div class="layui-inline">
                    <label class="layui-form-label">库存预警</label>
                    <div class="layui-input-inline">

                        <input type="text" name="dangernum" autocomplete="off" placeholder="请输入包装"
                               class="layui-input">

                    </div>
                </div>
                <div class="layui-inline">
                    <label class="layui-form-label">是否有效:</label>
                    <div class="layui-input-block">
                        <input type="radio" name="available" value="1" title="可用" checked="checked">
                        <input type="radio" name="available" value="0" title="不可用">
                    </div>
                </div>
            </div>

            <div class="layui-form-item" style="text-align: center;">
                <button type="button" class="layui-btn" lay-filter="doSubmit" lay-submit=""><span class='layui-icon'>&#xe609;</span>提交
                </button>
                <button type="reset" class="layui-btn layui-btn-danger"><span class='layui-icon'>&#xe669;</span>重置</button>
            </div>


        </div>

    </form>


</div>
<!-- 添加和修改的弹出层结束 -->
<script type="text/javascript" src="/layui/layui.js"></script>
<script type="text/javascript">
    layui.use(['table', 'form', 'layer', 'laydate', 'jquery','upload'], function () {
        var table = layui.table;
        var form = layui.form;
        var layer = layui.layer;
        var upload=layui.upload;
        var $ = layui.jquery;

        //下拉树
        $.get("/provider/loadAllAvailableProvider",function (res) {
            //searchProvider
            var a = "<option value=''>请选择供应商</option>"
            $.each(res.data,function (i,item) {
                a += "<option value="+item.id+">"+item.providername+"</option>"
            })
            $("#searchProvider").html(a);
            //表单重新渲染
            form.render();

        })

        //渲染数据表格
        var tableIns = table.render({
            elem: '#goodsTable'
            , url: '/goods/loadAllGoods'
            , toolbar: '#goodsTableToolBar' //开启头部工具栏，并为其绑定左侧模板
            ,defaultToolbar: ['filter', 'exports', 'print', { //自定义头部工具栏右侧图标。如无需自定义，去除该参数即可
                title: '提示'
                ,layEvent: 'LAYTABLE_TIPS'
                ,icon: 'layui-icon-tips'
            }]
            , title: '商品数据表'
            , height: 'full-150'
            , cols: [
                [
                    {type: 'checkbox', fixed: 'left'}
                    , {field: 'id', title: 'ID', align: 'center', fixed: 'left', unresize: true, sort: true}
                    , {field: 'goodsname', title: '商品名称', align: 'center', width: 150}
                    , {field: 'providername', title: '供应商', align: 'center', width: 150}
                    , {field: 'produceplace', title: '产地', align: 'center', width: 150}
                    , {field: 'number', title: '库存量', align: 'center', width: 150}
                    , {field: 'price', title: '价格', align: 'center', width: 150}
                    , {field: 'dangernum', title: '预警值', align: 'center', width: 150}
                    , {field: 'size', title: '规格', align: 'center', width: 150}
                    , {field: 'goodspackage', title: '包装', align: 'center', width: 150}
                    , {field: 'productcode', title: '生产批号', align: 'center', width: 150}
                    , {field: 'promitcode', title: '批准文号', align: 'center', width: 150}
                    , {field: 'description', title: '商品描述', align: 'center', width: 150}
                    , {field: 'goodsimg', title: '图片', align: 'center', width: 150,templet:function (d) {
                        return "<img width='30' height='30' src='/file/showImage?filePath="+d.goodsimg+"'>"

                    }}
                    , {field: 'available', title: '是否可用',width:150, align: 'center',templet:function (d) {
                        return d.available==1 ?"<font color='blue'>可用</font>":"<font color='red'>不可用</font>"
                    }
                    }
                    , {fixed: 'right', title: '操作', toolbar: '#goodsTableRowBar', align: 'center',width:150}
                ]
            ]
            , page: true
        });
        //模糊查询
        $("#doSearch").click(function () {
            var params = $("#searchFrm").serialize();
            tableIns.reload({
                url: '/goods/loadAllGoods?' + params
            })
        });
        //监听表头按钮的事件
        table.on('toolbar(goodsTable)', function (obj) {
            switch (obj.event) {
                case 'add':
                    openAddLayer();
                    break;
                case 'batchdel':
                    batchDelete(obj);
                    break;
            }
            ;
        });

        //监听行按钮的事件
        table.on('tool(goodsTable)', function (obj) {
            var data = obj.data; //获得当前行数据
            var layEvent = obj.event; //获得 lay-event 对应的值（也可以是表头的 event 参数对应的值）
            if (layEvent === 'update') { //修改
                openUpdateLayer(data);
            }  else if (layEvent === 'del') { //删除
                layer.confirm('真的删除该行么', function (index) {
                    //obj.del(); //删除对应行（tr）的DOM结构，并更新缓存
                    layer.close(index);
                    //向服务端发送删除指令
                    $.delete("/goods/deleteGoods", {id: data.id}, function (obj) {
                        if (obj.code == 200) {
                            tableIns.reload();//重载表格
                        }
                        layer.msg(obj.msg);
                    })
                });
            } else if (layEvent === 'view') { //查看
                viewGoods(data);
            }
        });

        var mainIndex;
        var url;

        //打开添加的弹出层
        function openAddLayer() {
            mainIndex = layer.open({
                type: 1,
                title: '添加商品',
                skin: 'layui-layer-molv', //加上边框
                area: ['800px', '520px'], //宽高
                content: $("#saveOrUpdateDiv"),
                success:function (index) {
                    url="/goods/addGoods";
                    //清空原来的数据
                    $("#dataFrm")[0].reset();


                    $.get("/provider/loadAllAvailableProvider",function (res) {
                        var h="<option value=''>请选择供应商</option>";
                        $.each(res.data,function (i,item) {
                            h +="<option value="+item.id+">"+item.providername+"</option>";
                        });
                        //alert(h);
                        $("#providerid").html(h);

                        //默认图片
                        $("#goodsimg").val("/resources/images/userface3.jpg");

                        $(".thumbImg").attr("src","/file/showImage?filePath=/img/1.jpg");

                        form.render();

                    });

                }
            })
        };


        //上传头像
        upload.render({
            elem: '.thumbImg',
            url: '/file/uploadFile',
            method: "post",  //此处是为了演示之用，实际使用中请将此删除，默认用post方式提交
            accept: 'images',
            acceptMime: 'image/*',
            field: 'mf',//<input type='file' name='mf'>
            done: function (res, index, upload) {

                //图片的imgpath重新赋值
                $("#goodsimg").val(res.data.src);

                $(".thumbImg").attr("src","/file/showImage?filePath="+res.data.src);
                form.render();

            }
        });



        //编辑
        function openUpdateLayer(data){
            mainIndex = layer.open({
                type: 1,
                title: '编辑商品',
                skin: 'layui-layer-molv', //加上边框
                area: ['800px', '520px'], //宽高
                content: $("#saveOrUpdateDiv"),
                success:function (index) {
                    $("#dataFrm")[0].reset();
                    url="/goods/updateGoods";

                    //给表单数据赋值
                    form.val("dataFrm",data);


                    $.get("/provider/loadAllAvailableProvider",function (res) {
                        var h="<option value=''>请选择供应商</option>";
                        $.each(res.data,function (i,item) {
                            if (item.id == data.providerid){
                                h +="<option value="+item.id+" selected=selected>"+item.providername+"</option>";
                            } else {
                                h +="<option value="+item.id+">"+item.providername+"</option>";
                            }



                        });
                        //alert(h);
                        $("#providerid").html(h);

                        //默认图片
                        $("#goodsimg").val("/resources/images/userface3.jpg");

                        $(".thumbImg").attr("src","/file/showImage?filePath=/img/1.jpg");

                        form.render();

                    });
                }
            })
        }

        //监听提交按钮的事件
        form.on("submit(doSubmit)", function (data) {
            var params=$("#dataFrm").serialize();
            //向后台发出请求
            $.post(url,params,function (obj) {
                if(obj.code==200){
                    //刷新表格
                    tableIns.reload();
                }
                layer.msg(obj.msg);
                layer.close(mainIndex);
            });
        });

        //批量删除
        function batchDelete(obj) {
            var checkStatus = table.checkStatus('goodsTable'); //idTest 即为基础参数 id 对应的值
            console.log(checkStatus.data) //获取选中行的数据
            console.log(checkStatus.data.length) //获取选中行数量，可作为是否有选中行的条件
            console.log(checkStatus.isAll) //表格是否全选
            if (checkStatus.data.length == 0) {
                layer.msg("请选中要删除的数据行");
            } else {
                layer.confirm('确定删除选中行么?', function (index) {
                    layer.close(index);
                    var params = "";
                    $.each(checkStatus.data, function (i, item) {
                        if (i == 0) {
                            params += "ids=" + item.id;
                        } else {
                            params += "&ids=" + item.id;
                        }
                    });
                    //向服务端发送删除指令
                    $.delete("/goods/batchDeleteGoods", params, function (obj) {
                        if (obj.code == 200) {
                            tableIns.reload();//重载表格
                        }
                        layer.msg(obj.msg);
                    })
                });
            }
        }
    });
</script>

</body>
</html>